class MinStack {
public:
    MinStack() {

    }

    void push(int val) {
        if (_st.empty() || val <= minst.top())
        {
            minst.push(val);
        }
        _st.push(val);
    }

    void pop() {
        if (_st.top() == minst.top())
        {
            minst.pop();
        }
        _st.pop();
    }

    int top() {
        return _st.top();
    }

    int getMin() {
        return minst.top();
    }
    stack<int> _st;
    stack<int> minst;
};
